<template>
  <div>
    <el-form :inline="true" v-show="isSearchCollapse" class="query-form" ref="searchForm" :model="searchForm"
      @keyup.enter.native="refreshList()" @submit.native.prevent>
      <!-- 搜索框-->
      <el-form-item prop="businessType">
        <el-select v-model="searchForm.businessType" placeholder="请选择业务类型" size="small" style="width: 100%">
          <el-option v-for="item in $dictUtils.getDictList('business_type')" :key="item.value" :label="item.label"
            :value="item.value">
          </el-option>
        </el-select>
      </el-form-item>
      <el-form-item prop="iconName">
        <el-input size="small" v-model="searchForm.iconName" placeholder="图标名称" clearable></el-input>
      </el-form-item>
      <el-form-item prop="whetherDefaultDisplay">
        <el-radio-group v-model="searchForm.whetherDefaultDisplay">
          <el-radio v-for="item in $dictUtils.getDictList('')" :label="item.value" :key="item.id">{{ item.label }}
          </el-radio>
        </el-radio-group>
      </el-form-item>
      <el-form-item prop="remarks">
        <el-input size="small" v-model="searchForm.remarks" placeholder="备注信息" clearable></el-input>
      </el-form-item>
      <el-form-item>
        <el-button type="primary" @click="refreshList()" size="small">查询</el-button>
        <el-button @click="resetSearch()" size="small">重置</el-button>
      </el-form-item>
    </el-form>
    <!-- 导入导出-->
    <el-form :inline="true" v-show="isImportCollapse" class="query-form" ref="importForm">
      <el-form-item>
        <el-button type="default" @click="downloadTpl()" size="small">下载模板</el-button>
      </el-form-item>
      <el-form-item prop="loginName">
        <el-upload class="upload-demo" :action="`${this.$http.BASE_URL}/commonpreferences/commonPreferences/import`"
          :on-success="uploadSuccess" :show-file-list="true">
          <el-button size="small" type="primary">点击上传</el-button>
          <div slot="tip" class="el-upload__tip">
            只允许导入“xls”或“xlsx”格式文件！
          </div>
        </el-upload>
      </el-form-item>
    </el-form>
    <el-row>
      <el-button v-if="hasPermission('commonpreferences:commonPreferences:add')" type="primary" size="small"
        icon="el-icon-plus" @click="add()">新建</el-button>
      <el-button v-if="hasPermission('commonpreferences:commonPreferences:edit')" type="warning" size="small"
        icon="el-icon-edit-outline" @click="edit()" :disabled="dataListSelections.length != 1" plain>修改</el-button>
      <el-button v-if="hasPermission('commonpreferences:commonPreferences:del')" type="danger" size="small"
        icon="el-icon-delete" @click="del()" :disabled="dataListSelections.length <= 0" plain>删除
      </el-button>
      <el-button-group class="pull-right">
        <el-button type="default" size="small" icon="el-icon-search" @click="
            (isSearchCollapse = !isSearchCollapse), (isImportCollapse = false)
          ">
        </el-button>
        <!-- <el-button v-if="hasPermission('commonpreferences:commonPreferences:import')" type="default" size="small"
          icon="el-icon-upload2" title="导入" @click="isImportCollapse = !isImportCollapse, isSearchCollapse=false">
        </el-button>
        <el-button v-if="hasPermission('commonpreferences:commonPreferences:export')" type="default" size="small"
          icon="el-icon-download" title="导出" @click="exportExcel()"></el-button> -->
        <el-button type="default" size="small" icon="el-icon-refresh" @click="refreshList">
        </el-button>
      </el-button-group>
    </el-row>
    <el-table :data="dataList" border size="medium" @selection-change="selectionChangeHandle"
      @sort-change="sortChangeHandle" v-loading="loading" class="table">
      <el-table-column type="selection" header-align="center" align="center" width="50">
      </el-table-column>
      <el-table-column prop="iconName" show-overflow-tooltip label="图标名称">
        <template slot-scope="scope">
          <el-link type="primary" :underline="false" v-if="hasPermission('commonpreferences:commonPreferences:edit')"
            @click="edit(scope.row.id)">{{ scope.row.iconName }}</el-link>
          <el-link type="primary" :underline="false" v-else-if="
              hasPermission('commonpreferences:commonPreferences:view')
            " @click="view(scope.row.id)">{{ scope.row.iconName }}</el-link>
          <span v-else>{{ scope.row.iconName }}</span>
        </template>
      </el-table-column>
      <el-table-column prop="icon" show-overflow-tooltip label="图标路径">
        <template slot-scope="scope" v-if="scope.row.icon">
          <el-image style="height: 50px; width: 50px; margin-right: 10px" :src="src"
            v-for="(src, index) in scope.row.icon.split('|')" :key="index"
            :preview-src-list="scope.row.icon.split('|')">
          </el-image>
        </template>
      </el-table-column>

      <el-table-column prop="businessType" show-overflow-tooltip label="业务类型">
        <template slot-scope="scope">
          {{
          $dictUtils.getDictLabel(
          "business_type",
          scope.row.businessType,
          "-"
          )
          }}
        </template>
      </el-table-column>
      <el-table-column prop="jumpLink" show-overflow-tooltip label="跳转链接">
      </el-table-column>
      <el-table-column prop="whetherDefaultDisplay" show-overflow-tooltip label="是否默认显示">
        <template slot-scope="scope">
          <span v-if="scope.row.whetherDefaultDisplay == 0">不默认</span>
          <span v-if="scope.row.whetherDefaultDisplay == 1">默认</span>
        </template>
      </el-table-column>
      <el-table-column prop="remarks" show-overflow-tooltip label="备注信息">
      </el-table-column>
      <el-table-column header-align="center" align="center" fixed="right" width="200" label="操作">
        <template slot-scope="scope">
          <el-button v-if="hasPermission('commonpreferences:commonPreferences:view')" type="text" icon="el-icon-view"
            size="small" @click="view(scope.row.id)">查看</el-button>
          <el-button v-if="hasPermission('commonpreferences:commonPreferences:edit')" type="text" icon="el-icon-edit"
            size="small" @click="edit(scope.row.id)">修改</el-button>
          <el-button v-if="hasPermission('commonpreferences:commonPreferences:del')" type="text" icon="el-icon-delete"
            size="small" @click="del(scope.row.id)">删除</el-button>
        </template>
      </el-table-column>
    </el-table>
    <el-pagination @size-change="sizeChangeHandle" @current-change="currentChangeHandle" :current-page="pageNo"
      :page-sizes="[10, 20, 50, 100]" :page-size="pageSize" :total="total" background
      layout="total, sizes, prev, pager, next, jumper">
    </el-pagination>
    <!-- 弹窗, 新增 / 修改 -->
    <CommonPreferencesForm ref="commonPreferencesForm" @refreshDataList="refreshList"></CommonPreferencesForm>
  </div>
</template>

<script>
  import CommonPreferencesForm from "./CommonPreferencesForm";
  export default {
    data() {
      return {
        searchForm: {
          businessType: "",
          iconName: "",
          whetherDefaultDisplay: "",
          remarks: "",
        },
        dataList: [],
        pageNo: 1,
        pageSize: 10,
        total: 0,
        orderBy: "",
        dataListSelections: [],
        isSearchCollapse: false,
        isImportCollapse: false,
        loading: false,
      };
    },
    components: {
      CommonPreferencesForm,
    },
    activated() {
      this.refreshList();
    },

    methods: {
      // 获取数据列表
      refreshList() {
        this.loading = true;
        this.$http({
          url: "/commonpreferences/commonPreferences/list",
          method: "get",
          params: {
            pageNo: this.pageNo,
            pageSize: this.pageSize,
            orderBy: this.orderBy,
            ...this.searchForm,
          },
        }).then(({ data }) => {
          if (data && data.success) {
            this.dataList = data.page.list;
            this.total = data.page.count;
            this.loading = false;
          }
        });
      },
      // 每页数
      sizeChangeHandle(val) {
        this.pageSize = val;
        this.pageNo = 1;
        this.refreshList();
      },
      // 当前页
      currentChangeHandle(val) {
        this.pageNo = val;
        this.refreshList();
      },
      // 多选
      selectionChangeHandle(val) {
        this.dataListSelections = val;
      },

      // 排序
      sortChangeHandle(obj) {
        if (obj.order === "ascending") {
          this.orderBy = obj.prop + " asc";
        } else if (obj.order === "descending") {
          this.orderBy = obj.prop + " desc";
        } else {
          this.orderBy = "";
        }
        this.refreshList();
      },
      // 新增
      add() {
        this.$refs.commonPreferencesForm.init("add", "");
      },
      // 修改
      edit(id) {
        id =
          id ||
          this.dataListSelections.map((item) => {
            return item.id;
          })[0];
        this.$refs.commonPreferencesForm.init("edit", id);
      },
      // 查看
      view(id) {
        this.$refs.commonPreferencesForm.init("view", id);
      },
      // 删除
      del(id) {
        let ids =
          id ||
          this.dataListSelections
            .map((item) => {
              return item.id;
            })
            .join(",");
        this.$confirm(`确定删除所选项吗?`, "提示", {
          confirmButtonText: "确定",
          cancelButtonText: "取消",
          type: "warning",
        }).then(() => {
          this.loading = true;
          this.$http({
            url: "/commonpreferences/commonPreferences/delete",
            method: "delete",
            params: { ids: ids },
          }).then(({ data }) => {
            if (data && data.success) {
              this.$message.success(data.msg);
              this.refreshList();
            }
            this.loading = false;
          });
        });
      },
      // 导入成功
      uploadSuccess(res, file) {
        if (res.success) {
          this.$message.success({
            dangerouslyUseHTMLString: true,
            message: res.msg,
          });
        } else {
          this.$message.error(res.msg);
        }
      },
      // 下载模板
      downloadTpl() {
        this.$utils.download(
          "/commonpreferences/commonPreferences/import/template"
        );
      },
      exportExcel() {
        this.$utils.download("/commonpreferences/commonPreferences/export");
      },
      resetSearch() {
        this.$refs.searchForm.resetFields();
        this.refreshList();
      },
    },
  };
</script>